算法入门教程(十大经典算法图解)
所谓算法(Algorithm),就是解决问题的方法。换句话说,算法提供了一整套解决问题的方案或者思路,也即先做什么,再做什么,最后做什么。学习算法,可以短时间内快速提升「遇到问题,解决问题」的能力。
算法的种类有很多(比如十大经典算法之类),本教程涵盖了几乎所有常用的算法,包括动态规划、分治、贪心、排序、查找等,每种算法用来解决某一类实际问题。
通常,解决一个问题的算法有很多,例如对某个序列进行排序,可以使用冒泡排序、选择排序、希尔排序等,有些算法运行效率高、有些效率差。这种情况下,我们需要具备挑选“好”算法的能力,阅读本套算法教程之后,你将具备这种能力。
教程特点
这套算法入门教程专为小白打造,如果您刚刚接触算法,或者对算法懵懵懂懂,那么本套算法教程非常适合您。
为了降低初学者的门槛,我们采用「图解+伪代码+源代码」的方式讲解每个算法。不仅如此,考虑到读者只掌握了 C/C++、Java 和 Python 中的某一门编程语言,本教程中的每个算法都同时配有 C/C++、Java 以及 Python 的实现源码。
本教程不是教科书,不会玩弄概念,而是力求口语化和通俗化,深入浅出地讲解每个算法,让读者尽快入门。
- 教程目录:
- 1. 算法是什么?(通俗易通,小白专享)
- 2. 时间复杂度和空间复杂度的概念(非常详细)
- 3. 递归算法(超级详细,图文并茂)
- 4. 斐波那契数列(非常详细,动图演示)
- 5. 分治算法的基本思想(图解)
- 6. 求数组中的最大值和最小值(动图演示,附带源码)
- 7. 多数元素问题(非常详细,图文并茂)
- 8. 汉诺塔问题(超级详细,动图演示)
- 9. 贪心算法的基本思想(通俗易懂)
- 10. 分发饼干问题(非常详细,附带源码)
- 11. 最大子序和问题(非常详细,附带源码)
- 12. 部分背包问题(非常详细,附带源码)
- 13. 动态规划算法的基本思想(非常详细)
- 14. 零钱兑换问题(非常详细,附带源码)
- 15. 01背包问题(超级详细,附带源码)
- 16. 完全背包问题(超级详细,附带源码)
- 17. 回溯算法的基本思想(通俗易懂)
- 18. 子集问题(非常详细,附带源码)
- 19. 组合问题(非常详细,附带源码)
- 20. 全排列问题(非常详细,附带源码)
- 21. 迷宫问题(非常详细,附带源码)
- 22. N皇后问题(非常详细,附带源码)
- 23. 冒泡排序算法(超级详细,图文并茂)
- 24. 双向冒泡排序算法(非常详细,动图演示)
- 25. 插入排序算法(非常详细,图文并茂)
- 26. 选择排序算法(非常详细,图文并茂)
- 27. 希尔排序算法(超级详细,动图演示)
- 28. 归并排序算法(非常详细,图文并茂)
- 29. 快速排序算法(超级详细,图文并茂)
- 30. 计数排序算法(非常详细,图文并茂)
- 31. 基数排序算法(非常详细,图文并茂)
- 32. 桶排序算法(非常详细,图文并茂)
- 33. 对排序算法的总结和提升
- 34. 顺序查找算法(非常详细,动图演示)
- 35. 二分查找(折半查找)算法详解,图文并茂
- 36. 插值查找算法(非常详细,图文并茂)
- 37. 哈希查找算法(非常详细,图文演示)
- 38. 并查集(超级详细,动图演示)
- 39. 寻找图中是否存在路径(非常详细,图文并茂)
- 40. 冗余连接问题(非常详细,图文并茂)
- 41. 最小生成树的概念与思想(通俗易懂)
- 42. prim算法(普里姆算法)详解,图文并茂
- 43. kruskal算法(克鲁斯卡尔算法)详解,图文并茂
- 44. 最短路径算法(图文并茂,通俗易懂)
- 45. 迪杰斯特拉算法求最短路径(超级详细,图文并茂)
- 46. 弗洛伊德算法求最短路径(非常详细,图文并茂)